package com.anzia.vueblog.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.env.Environment;
import org.springframework.core.env.Profiles;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;

/**
 *@ClassName SwaggerConfig
 *@Description
 *@Author Anzia.
 *@Date 2021/4/24 11:07
 *@Version 1.0
 **/
@Configuration
@EnableSwagger2 // 开启swagger2
public class SwaggerConfig {

    // 配置了Swagger的Docket的bean实例
    @Bean
    public Docket docket(Environment environment) {

        // 设置要显示的swagger环境
        Profiles profiles = Profiles.of("dev","test");

        // 获取项目的环境
        // 通过environment.acceptsProfiles判断是否处在自己设定的环境当中
        boolean flag = environment.acceptsProfiles(profiles);


        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                //配置API文档的分组
                .groupName("Anzia.")
                .enable(flag)
                .select()
                // RequestHandlerSelectors, 配置要扫描接口的方式
                // basePackage 指定要扫描的包
                // any() 扫描全部
                // none() 都不扫描
                // withClassAnnotation() 扫描类上的注解，参数是一个注解的反射对象
                // withMethodAnnotation() 扫描方法上的注解
                //.apis(RequestHandlerSelectors.basePackage("com.anzia.vueblog.blog.controller"))
                // path() 过滤什么路径
                //.paths(PathSelectors.ant("/kuang/**"))
                .build();
    }

    // 配置swagger信息 = apiInfo
    private ApiInfo apiInfo() {

        // 作者信息
        Contact contact = new Contact("Anzia.", "https://gitee.com/azw13455688", "347941618@qq.com");

        return new ApiInfo(
                "Anzia.的SwaggerAPI文档",
                "生命以负熵为食",
                "1.0",
                "https://gitee.com/azw13455688",
                contact,
                "Apache 2.0",
                "http://www.apache.org/licenses/LICENSE-2.0",
                new ArrayList()
        );
    }
}
